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A METHOD OF AND APPARATUS FOR BITMAP ANIMATION OF ON-SCREEN-DISPLAY GRAPHICS DATA OVER 
A DISTRIBUTED IEEE 1394 NETWORK UTILIZING HAVI ARCHITECTURE AND A CLIPPING REGION HAVING A 
VISIBLE WINDOW 

5 

RELATED APPLICATIONS : 

This application claims priority under 35 U.S.C. § 1 19(e) of the co-pending U.S. 
provisional application Serial Number 60,089,798 filed on June 18, 1998 and entitled n A 
METHOD FOR HANDLING HIGH BANDWIDTH ON-SCREEN-DISPLAY (OSD) 
10 OVER A DISTRIBUTED 1394 NETWORK." The provisional application Serial Number 
60,089,798 filed on June 18, 1998 and entitled "A METHOD FOR HANDLING HIGH 
BANDWIDTH ON-SCREEN-DISPLAY (OSD) OVER A DISTRIBUTED 1394 
NETWORK" is also hereby incorporated by reference. 



15 FIELD OF THE INVENTION : 

The present invention relates to the field of displaying on-screen-display graphics 
data on a display device. More particularly, the present invention relates to the field of 
displaying bitmap animation of on-screen-display graphics data on a display device. 

20 BACKGROUND OF THE INVENTION : 

The IEEE 1394-1995 standard, "1394 Standard For A High Performance Serial 
Bus," is an international standard for implementing an inexpensive high-speed serial bus 
architecture which supports both asynchronous and isochronous format data transfers. In 
addition, the IEEE 1394-1995 bus has a universal clock called the cycle timer. This clock 

25 is synchronized on all nodes. Isochronous data transfers are real-time transfers which take 
place based on the universal clock such that the time intervals between significant instances 
have the same duration at both the transmitting and receiving applications. Each packet of 
data transferred isochronously is transferred in its own time period. An example of an 
ideal application for the transfer of data isochronously would be from a video recorder to a 

30 television set. The video recorder records images and sounds and saves the data in discrete . 
chunks or packets. The video recorder then transfers each packet, representing the image 
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and sound recorded over a limited time period, during that time period, for display by the 
television set. The IEEE 1394-1995 standard bus architecture provides multiple 
independent channels for isochronous data transfer between applications. A six bit channel 
number is broadcast with the data to ensure reception by the appropriate application. This 
allows multiple applications to simultaneously transmit isochronous data across the bus 
structure. Asynchronous transfers are traditional reliable data transfer operations which 
take place as soon as arbitration is won and transfer a maximum amount of data from a 
source to a destination. 

The IEEE 1394-1995 standard provides a high-speed serial bus for interconnecting 
digital devices thereby providing a universal I/O connection. The IEEE 1394-1995 
standard defines a digital interface for the application thereby eliminating the need for an 
application to convert digital data to analog data before it is transmitted across the bus. 
Correspondingly, a receiving application will receive digital data from the bus, not analog 
data, and will therefore not be required to convert analog data to digital data. The cable 
required by the IEEE 1394-1995 standard is very thin in size compared to other bulkier 
cables used to connect such devices in other connection schemes. Devices can be added 
and removed from an IEEE 1394-1995 bus while the bus is operational. If a device is so 
added or removed the bus will then automatically reconfigure itself for transmitting data 
between the then existing nodes. A node is considered a logical entity with a unique 
address on the bus structure. Each node provides in a standard address space, an 
identification ROM, a standardized set of control registers and in addition, its own address 
space. 

The IEEE 1394-1995 standard defines a protocol as illustrated in Figure 1. This 
protocol includes a serial bus management block 10 coupled to a transaction layer 12, a 
link layer 14 and a physical layer 16. The physical layer 16 provides the electrical and 
mechanical connection between a device and the IEEE 1394-1995 cable. The physical 
layer 16 also provides arbitration to ensure that all devices coupled to the IEEE 1394-1995 
bus have arbitrated access to the bus as well as actual data transmission and reception. The 
link layer 14 provides data packet delivery service for both asynchronous and isochronous 
data packet transport. This supports both asynchronous data transport, using an 
acknowledgement protocol, and isochronous data transport, providing an un-acknowledged 
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real-time guaranteed bandwidth protocol for just-in-time data deliver)'. The transaction 
layer 12 supports the commands necessary to complete asynchronous data transfers, 
including read, write and lock. The serial bus management block 10 contains an 
isochronous resource manager for managing isochronous data transfers. The serial bus 

5 management block 10 also provides overall configuration control of the serial bus in the 

form of optimizing arbitration timing, guarantee of adequate electrical power for all devices 
on the bus ? assignment of the cycle master, assignment of isochronous channel and 
bandwidth resources and basic notification of errors. 

A home audio/video interoperability (HAVi) architecture is defined by "The HAVi 

10 Architecture: Specification of the Home Audio/Video Interoperability (HAVi) 

Architecture," draft version 0.8nl3, September 16, 1998. The HAVi architecture is to be 
implemented on consumer electronics devices and computing devices. The HAVi 
architecture provides a set of services which facilitate interoperability and the development 
of distributed applications on home networks. The HAVi architecture is designed for 

15 digital devices coupled together within an IEEE 1394-1995 serial bus network. 

The HAVi architecture defines two on-screen-display graphics models, referred to as 
level 1 and level 2. The level 1 on-screen-display graphics model is a descriptive model in 
which the target device provides, through a series of commands from the control device, 
data structures which describe the intended on-screen-display graphics. Using a graphics 

20 library applications programming interface, the display device uploads this information and 
constructs the display graphics, which may or may not look as the target device intended. 
The level 2 on-screen-display graphics model defines a runtime execution environment, 
where the display device uploads executable code which runs on the display device itself 
This executable code is then used to generate the on-screen-display graphics using facilities 

25 provided by the display device. Using the HAVi architecture, a source device such as a 

digital VCR can generate data which is transmitted to the display device and utilized by the 
display device to generate the on-screen-display graphics. 

SUMMARY OF THE INVENTION : 
30 A method of and apparatus for bitmap animation and display of on-screen-display 

graphics utilizes the HAVi architecture and displays the bitmap animation using a clipping 
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region and a visible window. Data for a bitmap image of on-screen-display graphics is 
generated by a graphics source within a source device. The data is transmitted to a display 
device including a rendering engine. The bitmap image is then rendered by the display 
device. A clipping region and visible window are applied to the bitmap image as it is 
displayed by the display device. Only the portion of the bitmap image corresponding to 
the logical intersection of the visible window and the clipping region is displayed by the 
display device. The clipping region, visible window and the bitmap image can be moved 
in relation to each other through an animation sequence. The bitmap image can also be 
changed to generate animation within the clipping region. The size, position, path and 
other attributes of the clipping region are set within a bitmap animation object structure. 
Data for an object can also be generated by the source device and transmitted to the display 
device. The object can be moved through an animation sequence when displayed by the 
display device. Images or animation sequences can be displayed on or in the object. 

In one aspect of the present invention, a display through which a rendered image is 
displayed includes a visible window applied to a first portion of the rendered image and a 
clipping region through which only a second portion of the rendered image is visible. The 
clipping region can be moved in relation to the rendered image. The rendered image can 
be moved in relation to the clipping region. A source device is configured to generate data 
related to the rendered image, the clipping region and the visible window. The display still 
further includes a rendering engine coupled to the source device to render the rendered 
image and apply the clipping region and the visible window. The displayed image is 
preferably a bitmap image. The rendering engine is preferably coupled to the source 
device by a high speed serial interface. The data is preferably generated according to 
HAVi architecture. Alternatively, the data is generated according to the AV/C panel 
subunit. Preferably, the high speed serial interface is an IEEE 1394 serial bus. 

In another aspect of the present invention, a method of generating on-screen-display 
graphics on a display device includes the steps of generating on-screen-display graphics 
data at a source device relating to a bitmap image, clipping region and visible window, 
transmitting the on-screen-display graphics data to the display device, rendering the bitmap 
image at the display device, applying the clipping region and the visible window to the 
bitmap image and displaying only a first portion of the bitmap image corresponding to an 
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intersection of the visible window and the clipping region. A second portion of the bitmap 
image outside of the intersection of the visible window and the clipping region is masked. 
The method further includes the step of generating an animation effect by moving the 
clipping region in relation to the bitmap image. The method also includes the step of 
5 generating an animation effect by moving the bitmap image in relation to the clipping 
region. The method also includes the step of storing the bitmap image at the display 
device. The source device is preferably coupled to the display device by a high speed 
serial interface. Preferably, the high speed serial interface is an IEEE 1394 serial bus. The 
on-screen-display graphics data is generated according to HAVi architecture. Alternatively, 

10 the on-screen-display graphics data is generated according to the AV/C panel subunit. 

In yet another aspect of the present invention, a method of generating an object on 
a display device includes the steps of generating on-screen-display graphics data at a source 
device relating to the object, transmitting the on-screen-display graphics data to the display 
device, rendering the object at the display device, displaying the object at the display 

15 device and generating an animation effect by moving the object along a path prescribed by 
the on-screen-display graphics data. The method further includes the step of displaying 
one or more images on the object. The source device is preferably coupled to the display 
device by a high speed serial interface. Preferably, the high speed serial interface is an 
IEEE 1394 serial bus. The on-screen-display graphics data is preferably generated 

20 according to HAVi architecture. Alternatively, the on-screen-display graphics data is 
generated according to the AV/C panel subunit. 

In still another aspect of the present invention, a system for generating and 
displaying images includes a source device having a graphics source for generating on- 
screen-display graphics data relating to a bitmap image, clipping region and visible window 

25 and a source interface circuit coupled to the graphics source for transmitting the on-screen- 
display graphics data and a display device having a display interface circuit coupled to the 
source interface circuit for receiving the on-screen-display graphics data, a rendering engine 
coupled to the display interface circuit for receiving the on-screen-display graphics data, 
rendering the bitmap image and applying the clipping region and the visible window to the 

30 bitmap image and a display coupled to the rendering engine for displaying only a first 

portion of the bitmap image corresponding to an intersection of the visible window and the 
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clipping region. A second portion of the bitmap image outside of the intersection of the 
visible window and the clipping region is masked. The bitmap image can be moved in 
relation to the clipping region. The clipping region can be moved in relation to the bitmap 
image. The display interface circuit is preferably coupled to the source interface circuit by 
a high speed serial interface. Preferably, the high speed serial interface is an IEEE 1394 
serial bus. The on-screen-display graphics data is preferably generated according to HAVi 
architecture. Alternatively, the on-screen-display graphics data is generated according to 
the AV/C panel subunit. The system further includes a memory buffer coupled to the 
rendering engine for storing the bitmap image. 

BRIEF DESCRIPTION OF THE DRAWINGS : 

Figure 1 illustrates a protocol defined by the IEEE 1394-1995 standard. 

Figure 2 illustrates a block diagram of an exemplary network of devices according 
to the present invention, including a television and a VCR. 

Figure 3 illustrates a bitmap image of on-screen-display graphics displayed on the 
display 62. 

Figure 4 illustrates a bitmap image of on-screen-display graphics displayed using a 
clipping region and visible window according to the present invention. 

Figure 5 illustrates a bitmap image of on-screen-display graphics displayed wherein 
the bitmap image is shifted in relation to the visible window and clipping region. 

Figure 6 illustrates a bitmap image of on-screen-display graphics displayed wherein 
the clipping region is shifted in relation to the bitmap image. 

Figure 7 illustrates an animation object according to the present invention, displayed 
on the display 62. 

Figure 8 illustrates a prescribed path along which the animation object is moved. 

DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENT : 

A clipping region and a visible window are used to display bitmap animation 
preferably generated utilizing the HAVi architecture. Data for a bitmap image of on- 
screen-display graphics is generated by a graphics source within a source device. The data 
is Transmitted to a display device including a rendering engine. The bitmap image is then 
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rendered by the display device and stored within a local graphics buffer. The clipping 
region and visible window are applied to the bitmap image as it is displayed by the display 
device. Only the portion of the bitmap image corresponding to the logical intersection of 
the visible window and the clipping region is displayed by the display device. The visible 
window, clipping region and the bitmap image can be moved in relation to each other 
through an animation sequence. The bitmap image can also be changed to generate 
animation within the clipping region. The size, position, path and other attributes of the 
visible window and clipping region are set within a bitmap animation object structure. 

Data for an object can also be generated by the source device and transmitted to the 
display device. The object can be moved through an animation sequence when displayed 
by the display device. Images or animation sequences can be displayed on or in the object. 

A block diagram of an exemplary network of devices including a television 60 and 
a VCR 100 connected together by an IEEE 1394-1995 cable 90 is illustrated in Figure 2. 
Relevant components of the television 60 and the VCR 100 are also illustrated in Figure 2. 
The television 60 includes an IEEE 1394-1995 interface circuit 86 through which data and 
commands are sent to and received from the VCR 100. The IEEE 1394-1995 interface 
circuit 86 includes a physical interface circuit 88. The physical interface circuit 88 is 
coupled to the VCR 100 by the IEEE 1394-1995 serial bus cable 90. The IEEE 1394-1995 
interface circuit 86 is coupled to an audio/video switch 74 for providing video data from 
the VCR 100. The IEEE 1394-1995 interface circuit 86 is also coupled to a graphics 
applications programming interface 68 for receiving data representing on-screen-display 
graphics to be generated and displayed by the television 60. The television 60 also 
includes one or more local applications 70 which are coupled to a graphics applications 
programming interface 68 for receiving data representing on-screen-display graphics to be 
generated and displayed by the television 60. The graphics applications programming 
interface 68 is coupled to a rendering engine 66 which receives the data and generates 
appropriate on-screen-display graphics from the data. The rendering engine 66 is coupled 
to a local graphics buffer 71 for storing bitmap images generated according to the present 
invention and displayed through a visible window. The rendering engine 66 and the local 
graphics buffer 71 are also coupled to the VRAM circuit 64 to provide the generated on- 
screen-display graphics to the VRAM circuit 64. 
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The television 60 also includes a cable/antenna interface circuit 82 which is coupled 
to receive input signals from a coaxial cable or an antenna and to pass those signals 
through a tuner 80 to the audio/video switch 74. The audio/video switch 74 is coupled to a 
decoding circuit 72 for decoding any encoded video signals and providing the decoded 
5 video signals to the VRAM circuit 64. The VRAM circuit 64 is coupled to the display 62 
for providing the video signals to the display 62. 

The VCR 100 includes an IEEE 1394-1995 interface circuit 102 through which data 
and commands are sent to and received from the television 60. The IEEE 1394-1995 
interface circuit 102 includes a physical interface circuit 104. The physical interface circuit 

10 104 is coupled to the television 60, over the IEEE 1394-1995 serial bus cable 90. The 

VCR 100 includes a video source 106, such as a video tape, which is being played by the 
VCR 100, or a television input. The video source 106 is coupled to the IEEE 1394-1995 
interface circuit 102 for transmitting video streams of data over the IEEE 1394-1995 serial 
bus cable 90 to the television 60. The VCR 100 also includes a graphics source 108 which 

1 5 generates data, preferably in the HAVi architecture, related to on-screen-display graphics to 
be displayed by the television 60. The graphics source 108 is coupled to the IEEE 1394- 
1995 interface circuit 102 for transmitting the graphics data over the IEEE 1394-1995 
serial bus cable 90 to the television 60. 

The configuration illustrated in Figure 2 is exemplary only. It should be apparent 

20 that an audio/video network could include many different combinations of components. It 
should be recognized that data, commands and parameters can be sent in either direction 
between the devices within the IEEE 1394-1995 network, as appropriate. 

Utilizing the present invention, the VCR 100 transmits graphics data generated by 
the graphics source and related to on-screen-display graphics to be displayed by the 

25 television 60. Preferably, the graphics data is generated according to the HAVi 

architecture. The on-screen-display graphics data is generated by the graphics source 108 
and preferably transmitted to the television 60 over the IEEE 1394-1995 serial bus cable 
90. 

When received by the television 60, the on-screen-display graphics data is received 
30 by the interface circuit 86 and transmitted to the graphics applications programming 

interface 68. The graphics applications programming interface 68, in conjunction with the 
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rendering engine 66, generates the on-screen-display graphics specified in the data received 
from the VCR 100. When generated, the on-screen-display graphics are then preferably 
loaded into the local graphics buffer 71. From the local graphics buffer 71, the on-screen- 
display graphics are either transmitted to the VRAM circuit 64 as full images or a clipping 
region and visible window are applied to the images and only a portion of the image is 
transferred to the VRAM circuit 64, as will be described in detail below. In either event, 
from the local graphics buffer 71, the bitmap images to be displayed are then loaded in the 
VRAM circuit 64 to be displayed by the display 62. An example of an entire bitmap 
image of on-screen-display graphics data displayed on the display 62, generated by the 
rendering engine 66 from data received from the VCR 100 is illustrated in Figure 3. This 
graphics scene 1 10 was generated by the rendering engine 66 from data received from the 
VCR 100. The rendering engine 66 generates the graphics scene 110 and loads it into the 
VRAM 64 to be shown on the display 62 at the appropriate time. 

When on-screen-display graphics data is sent from the VCR 100 to a display device 
according to the present invention, the on-screen-display graphics data is rendered and 
displayed after applying a clipping region and a visible window, as illustrated in Figure 4. 
The visible window preferably corresponds to a size of the display on the display device 
and includes the portion of the on-screen-display graphics data which fits into the size of 
the visible window. Alternatively, the visible window can be sized to correspond to any 
appropriate portion of the display and includes the portion of the on-screen-display graphics 
data which fits into the size of the visible window. If the on-screen-display graphics data 
is larger than the size of the visible window, the visible window is applied to the graphics 
scene to capture the portion of the graphics scene corresponding to the visible window. 
The graphics scene can be repositioned in relation to the visible window so that different 
portions of the graphics scene are positioned within the visible window. The graphics 
scene can also be scaled to fit within the visible window. 

Within the graphics scene 1 10, only the portion within the logical intersection of the 
clipping region 112 and the visible window 114 is visible to the user. In this example, 
because the entire clipping region 112 is positioned within the visible window 114, the 
portion of the graphics scene 110 corresponding to the position of the clipping region 112 
is visible to the viewer. The remainder of the graphics scene 110, outside of the clipping 
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region 112. is masked from view by the user. Within the portion of the display 62 outside 
of the logical intersection between the clipping region 1 12 and the visible window 1 14, 
another video stream can be displayed, another on-screen-display graphics scene can be 
displayed or nothing at all can be displayed, depending on the specific configuration and 
desired animation effect. 

The size, shape and orientation of the clipping region 112 can be changed, 
preferably by the user entering commands into the television 60 or VCR 100 through an 
appropriate input device. Also, the position of the clipping region 112 can be changed in 
relation to the graphics scene 1 10 and the visible window 1 14 to allow the user to view 
other portions of the graphics scene 1 1 0 and to generate an animation effect of scrolling. 
The visible window 1 1 4 and the graphics scene 1 1 0 can be re-oriented in relation to the 
clipping region 1 1 2 to allow a user to see a different portion of the graphics scene 110 
through the intersection of the clipping region 112 and the visible window 114, as 
illustrated in Figure 5. In this figure, the graphics scene 1 10 is shown with a portion 
outside of the display 62 only to illustrate the operation of the present invention. The 
position of the clipping region 1 12 can also be changed in relation to the graphics scene 
110 and the visible window 114 to allow a user to see a different portion of the graphics 
scene 110, as illustrated in Figure 6. 

By moving either the clipping region 112 in relation to the graphics scene 1 10 and 
the visible window 114, or the graphics scene 110 and the visible window 114 in relation 
to the clipping region 112, a scrolling window animation feature is generated for on-screen- 
display graphics. As discussed above, the graphics scene 110 can also be moved in 
relation to the visible window 114 in order to generate changing graphics within the visible 
window 114. It should also be understood that a series of bitmap images can be displayed 
using the clipping region and visible window of the present invention to generate an 
animated video stream within the clipping region 112. 
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The graphics scene 1 10, the visible window 1 14 and the clipping region 1 12 are 
formed within a bitmap animation object structure. The preferred structure of the bitmap 
animation object in interface definition language (1DL) code is listed below: 

Struct BitmapAnimation { 

Bitmap imageData; 
Region visibleWindow; 
Position deltalmagePosition; 
Position deltaClipPosition; 
Position deltaWindowPosition; 
Region clipRegion; 
unsigned short duration; 
Boolean animating; 
other attributes 



} 

This bitmap animation object structure includes the data for the bitmap image or graphics 
scene and its size. The bitmap animation object structure also includes the attributes of the 
clipping region 112 and the visible window 1 14, defining the size and shape of the area 
which acts as a mask over the bitmap image. Preferably, the area inside the defined 
clipping region refers to some portion of the visible window 1 14 and is visible to the user. 
The portion of the bitmap image outside of the intersection of the visible window 1 14 and 
the defined clipping region 112 is not visible to the user. The bitmap animation object 
structure also includes an animation direction composed of different or delta values for x 
and y directions. When the animation direction is triggered, the bitmap image is preferably 
shifted in the direction specified by the x and y delta values. Alternatively, when the 
animation direction is triggered, the clip region is shifted in the direction specified by the x 
and y delta values. The bitmap animation object structure additionally includes a duration 
value, over which the animation is to take place. The duration value is a time value, 
preferably in increments of 0.1 seconds. Once the animating or shifting begins, it takes an 
amount of time specified by the duration value to reach the position specified by the 
animation direction x and y delta values. The bitmap animation object structure further 
includes an animating status value which indicates whether or not the animating or shifting 
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is currently taking place. The animating status value also acts as a trigger to start and stop 
the animating process. Alternatively, specific commands are sent to start and stop the 
animating process. The other attributes field within the bitmap animation object structure 
includes application specific values, specified by the HAVi architecture, such as selectable, 
repetition, position, focus sound, font, focus navigation and relation. 

Using the architectural rules defined by the HAVi architecture, the display device 
60 extracts the on-screen-display graphics data from the source device 100. A bitmap 
image graphics scene 110 is then rendered by the display device 60. The on-screen-display 
graphics displayed to the user on the display 62 are generated by first generating the entire 
bitmap image 110, saving it into the local graphics buffer 71, then applying the clipping 
region 112 and the visible window 114 to the bitmap image 110. This results in only the 
portion of the graphics scene 110 within the logical intersection of the visible window 1 14 
and the clipping region 112 being visible to the user. 

The value of the animating status value within the initial bitmap animation object 
structure indicates whether an animating or shifting sequence is to begin immediately when 
the bitmap image is displayed or at some later time. If the animating sequence is not to 
begin immediately, then some trigger event will cause the animating state to change. The 
trigger event is an event causing a change in the animating state, such as a user selecting 
the animating feature or the source device 100 specifying that the animating state should 
change. When a triggering event occurs, the source device 100 preferably notifies the 
display device 60 according to the procedure specified within the HAVi architecture. In 
this notification message, the bitmap animation object structure is included with the 
changed animating status value. The notification message sent after a trigger event, can 
include changed values relating to the bitmap image, clip region, delta position, duration, 
animation state and any other specified attributes. 

If the display device receives a notification message with a changed bitmap 
animation object structure, then the display device examines the bitmap animation object 
structure to determine what value or values have been changed. If the animating status 
value is changed, the display device 60 then starts, stops or changes the animation sequence 
as specified by the animating status value. If the animating status value is changed to a 
start value and the delta x and y values are changed to equal "50" and "-10," respectively, 
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the display device 60 shifts the bitmap image 110 in relation to the clipping region 112, as 
specified by the delta x and y values. Preferably, the delta x and y values specify change 
in position by a change of a specified number of pixels. A positive value for a delta x or y 
value, indicates a change to the right or up, respectively. A negative value for a delta x or 
5 y value, indicates a change to the left or down, respectively. In this example, a delta x 

value of "50" specifies a change of 50 pixels in the horizontal direction to the right of the 
position of the bitmap image 110. A delta y value of "-10" specifies a change of 10 pixels 
of the position of the bitmap image 110 in the down vertical direction. Such a change is 
illustrated in the relative position of the bitmap image of Figure 5, in relation to the 
1 0 position of the bitmap image of Figure 4. 

Alternatively, a changed animated status value and delta x and y values relate to a 
change of the position of the clipping region 1 12 on the display 62 and in relation to the 
bitmap image 110 and the visible window 114. This creates a visual effect of animating 
the clipping region 1 12 in relation to the bitmap image 1 10. Rather than an image 
1 5 scrolling through the clipping region 1 12, the clipping region 1 12 is moving around on the 
display 62 and in relation to the bitmap image 1 10 and the visible window 1 14, with the 
viewable portions of the bitmap image 110 changing with the movement of the clipping 
region 112. 

On-screen-display graphics data for the entire bitmap image are preferably sent from 
20 the source device 100 to the display device 60. The display device 60 then renders the 
appropriate on-screen-display graphics for the specified bitmap image. The animating or 
shifting of the bitmap image in relation to the visible window 1 12 is managed, by the 
rendering engine 66, using the local graphics buffer 71. This allows smooth animation of a 
bitmap image 110 and a clipping region 112, on the display 62. Having the display device 
25 60 render the on-screen-display graphics and manage the animation also allows a much 
simpler source device 1 10 which does not have to calculate the delta pixels of a shifting 
bitmap image and communicate them to the display device 60. 

The bitmap animation sequence of the present invention also allows a visible object, 
such as an icon or bitmap image, to move around on the display, if appropriate. The 
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preferred structure of this object animation in IDL code is listed below: 

Struct ObjectAnimation { 

Bitmap imageData; 
5 Sequence <Position> trajectory; 

unsigned short duration; 
Boolean animating; 
Position currentPosition; 
other attributes 

10 

} 

Within this object animation structure, the sequence <Position> field defines an arbitrary 

15 collection of position data structures, relating to vertexes of a path along which the object 
is animated. Preferably, this path is defined by straight lines between positions on the 
screen. Alternatively, the path can be defined by a combination of straight lines, curves or 
arcs, which allow more complex motions. 

The setup procedure for displaying an object structure is similar to that described 

20 above for a bitmap image. The display device 60 first extracts the on-screen-display 

graphics data for the object from the source device 100. The object 120 is then rendered 
by the display device 60, on the display 62, as illustrated in Figure 7. If an animating 
sequence is then triggered, the object 120 is appropriately moved around the display 62. 
When the animation sequence is triggered, the display device 60 shifts the object on the 

25 display 62 according to the prescribed path and position data structures. Such a path is 
illustrated in Figure 8. Each of the legs of the path has an associated speed value S to 
allow the appearance of the object 120 speeding up and slowing down along the path. The 
object 120 is first positioned at the start position P0. From the start position P0, the object 
120 is moved along a straight line to the position PI, at the speed SI. From the position 

30 PL the object 120 is then moved along a curve to the position P2, at the speed S2. From 
the position P2, the object 120 is then moved along a straight line to the final position P3, 
at the speed S3. 

In an alternate embodiment, the object 120 is animated as it is travelling along the 
path, allowing a series of bitmap images to be shown within or on the object 120. Such 
35 bitmap images can be provided as a HAVi animation object. As the object 120 is moved 
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along the path, the images of the animation are cycled through within the object 120. 

In a further alternate embodiment, the object includes additional attributes 
describing its orientation. Accordingly, as the object 120 is moved along the path, it can 
also be rotated. This rotation information is synchronized to the legs of the path, 
indicating an initial rotation value and the number of rotations that the object is to go 
through as it travels that leg of the path. 

In the manner described herein, the bitmap animation of the present invention 
allows a source device to communicate on-screen-display graphics data for a bitmap image 
to a display device. The source device also communicates a bitmap animation object 
structure to the display device. The display device then renders the bitmap image utilizing 
a local graphics buffer 71. The bitmap animation object structure is applied to the bitmap 
image to clip the image so that only a portion of the image within a logical intersection of 
the visible window and the clipping region is shown to a user. The remainder of the 
bitmap image is masked from view of the user. The bitmap image can then be moved in 
relation to the clipping region along a prescribed path to give the appearance of the image 
scrolling through the clipping region. The bitmap image can also be moved in relation to 
the visible window in order to generate changing graphics within the visible window. The 
clipping region can also be moved in relation to the bitmap image and the visible window 
along a prescribed path to give the appearance of the clipping region scrolling over the 
bitmap image. An object animation structure is also defined for generating an object to be 
displayed to the user. The object can be moved around the display along a prescribed path. 
Animation sequences of images can also be displayed on the object as it is displayed and 
moved along the prescribed path. 

The present invention has been described in terms of specific embodiments 
incorporating details to facilitate the understanding of principles of construction and 
operation of the invention. Such reference herein to specific embodiments and details 
thereof is not intended to limit the scope of the claims appended hereto. It will be 
apparent to those skilled in the art that modifications may be made in the embodiment 
chosen for illustration without departing from the spirit and scope of the invention. 
Specifically, it will be apparent to those skilled in the art that while the preferred 
embodiment of the present invention is used with an IEEE 1394-1995 serial bus structure, 
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the present invention could also be implemented on any other appropriate bus structures, 
including other or later versions of the IEEE 1394 serial bus. It will also be apparent that 
while the preferred embodiment of the present invention uses the HAVi architecture to 
generate and transmit data for a bitmap image of on-screen-display graphics, any other 
appropriate protocol can be used to generate and transmit the graphics data, including the 
AV/C panel subunit. 
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CLAIMS 



We Claim: 

A display through which a rendered image is displayed comprising: 
a visible window applied to a first portion of the rendered image; and 
a clipping region through which only a second portion of the rendered image 
is visible. 

2. The display as claimed in claim 1 wherein the second portion is within the 
first portion. 

3. The display as claimed in claim 2 wherein the clipping region is moved in 
relation to the rendered image. 

4. The display as claimed in claim 2 wherein the rendered image is moved in 
relation to the clipping region. 

5. The display as claimed in claim 2 further comprising a source device 
configured to generate data related to the rendered image, the clipping region and the 
visible window. 



1. 

a. 
b. 



6. The display as claimed in claim 5 further comprising a rendering engine 
coupled to the source device to render the rendered image and apply the clipping region 
and the visible window. 

7. The display as claimed in claim 6 wherein the displayed image is a bitmap 
image. 

8. The display as claimed in claim 7 wherein the rendering engine is coupled to 
the source device by a high speed serial interface. 
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1 9. The display as claimed in claim 8 wherein the data is generated according to 

2 the HAVi architecture. 

1 10. The display as claimed in claim 8 wherein the data is generated according to 

2 AV/C panel subunit. 

1 11. The display as claimed in claim 8 wherein the high speed serial interface is 

2 an IEEE 1394 serial bus. 

1 12. A method of generating on-screen-display graphics on a display device 

2 comprising the steps of: 

3 a. generating on-screen-display graphics data at a source device relating to a 

4 bitmap image, clipping region and visible window; 

5 b. transmitting the on-screen-display graphics data to the display device; 

6 c. rendering the bitmap image at the display device; 

7 d. applying the clipping region and the visible window to the bitmap image; 

8 and 

9 e. displaying only a first portion of the bitmap image corresponding to an 
10 intersection of the visible window and the clipping region. 

1 13. The method as claimed in claim 12 wherein a second portion of the bitmap 

2 image outside of the intersection of the visible window and the clipping region is masked. 

1 14. The method as claimed in claim 12 further comprising the step of generating 

2 an animation effect by moving the clipping region in relation to the bitmap image. 

1 15. The method as claimed in claim 12 further comprising the step of generating 

2 an animation effect by moving the bitmap image in relation to the clipping region. 

1 16. The method as claimed in claim 12 further comprising the step of storing the 

2 bitmap image at the display device. 
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17. The method as claimed in claim 12 wherein the source device is coupled to 
the display device by a high speed serial interface. 

18. The method as claimed in claim 17 wherein the high speed serial interface is 
an IEEE 1394 serial bus. 

19 The method as claimed in claim 12 wherein the on-screen-display graphics 

data is generated according to HAVi architecture. 

20. The method as claimed in claim 12 wherein the on-screen-display graphics 
data is generated according to AV/C panel subunit. 

21. A method of generating an object on a display device comprising the steps 
of: 

a. generating on-screen-display graphics data at a source device relating to the 



object; 

b. transmitting the on-screen-display graphics data to the display device; 

c. rendering the object at the display device; 

d. displaying the object at the display device; and 

e. generating an animation effect by moving the object along a path prescribed 
by the on-screen-display graphics data. 



22. The method as claimed in claim 21 further comprising the step of rotating 
the object as it moves along the path. 

23. The method as claimed in claim 22 wherein the object moves at a 
predetermined speed along the path. 

24. The method as claimed in claim 21 further comprising the step of displaying 
one or more images on the object. 
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1 25. The method as claimed in claim 21 wherein the source device is coupled to 

2 the display device by a high speed serial interface. 

1 26. The method as claimed in claim 25 wherein the high speed serial interface is 

2 an IEEE 1394 serial bus. 

1 27. The method as claimed in claim 25 wherein the on-screen-display graphics 

2 data is generated according to the HAVi architecture. 

1 28. The method as claimed in claim 25 wherein the on-screen-display graphics 

2 data is generated according to AV/C panel subunit. 

1 29. A system for generating and displaying images comprising: 

2 a. a source device including: 

3 i. a graphics source for generating on-screen-display graphics data 

4 relating to a bitmap image, clipping region and visible window; and 

5 ii. a source interface circuit coupled to the graphics source for 

6 transmitting the on-screen-display graphics data; and 

7 b. a display device including: 

8 i. a display interface circuit coupled to the source interface circuit for 

9 receiving the on-screen-display graphics data; 

10 ii. a rendering engine coupled to the display interface circuit for 

1 1 receiving the on-screen-display graphics data, rendering the bitmap 

12 image and applying the clipping region and the visible window to the 

13 bitmap image; and 

14 iii. a display coupled to the rendering engine for displaying only a first 

1 5 portion of the bitmap image corresponding to an intersection of the 

16 visible window and the clipping region. 

1 30. The system as claimed in claim 29 wherein a second portion of the bitmap 

2 image outside of the intersection of the visible window and the clipping region is masked. 
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31. The system as claimed in claim 29 wherein the bitmap image is moved in 
relation to the clipping region. 

32. The system as claimed in claim 29 wherein the clipping region is moved in 
relation to the bitmap image. 

33. The system as claimed in claim 32 wherein the display interface circuit is 
coupled to the source interface circuit by a high speed serial interface. 

34. The system as claimed in claim 33 wherein the high speed serial interface is 
an IEEE 1394 serial bus. 

35. The system as claimed in claim 29 wherein the on-screen-display graphics 
data is generated according to HAVi architecture. 

36. The system as claimed in claim 29 wherein the on-screen-display graphics 
data is generated according to AV/C panel subunit. 

37. The system as claimed in claim 29 further comprising a memory buffer 
coupled to the rendering engine for storing the bitmap image. 
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